<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "https://www.w3.org/TR/html4/loose.dtd">
<html lang="zh-CN"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"><meta http-equiv="Content-Language" content="zh-CN"><link href="stylesheet.css" media="all" rel="stylesheet" type="text/css">
<title>介绍</title>
<script> var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?d286c55b63a3c54a1e43d10d4c203e75"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); </script>
</head><body class="SECT1">
<div>
<table summary="Header navigation table" width="100%" border="0" cellpadding="0" cellspacing="0">
<tr><th colspan="5" align="center" valign="bottom">PostgreSQL 8.2.3 中文文档</th></tr>
<tr><td width="10%" align="left" valign="top"><a href="mvcc.html" accesskey="P">后退</a></td><td width="10%" align="left" valign="top"><a href="mvcc.html">快退</a></td><td width="60%" align="center" valign="bottom">章12. 并发控制</td><td width="10%" align="right" valign="top"><a href="mvcc.html">快进</a></td><td width="10%" align="right" valign="top"><a href="transaction-iso.html" accesskey="N">前进</a></td></tr>
</table>
<hr align="LEFT" width="100%"></div>
<div class="SECT1"><h1 class="SECT1"><a name="MVCC-INTRO">12.1. 介绍</a></h1><a name="AEN16334"></a>
<p>PostgreSQL 为开发者提供了丰富的对数据并发访问进行管理的工具。在内部，PostgreSQL 利用多版本并发控制(MVCC)来维护数据的一致性。这就意味着当检索数据时，每个事务看到的都只是一小段时间之前的数据快照(一个<i class="FIRSTTERM">数据库版本</i>)，而不是数据的当前状态。这样，如果对每个数据库会话进行<i class="FIRSTTERM">事务隔离</i>，就可以避免一个事务看到其它并发事务的更新而导致不一致的数据。</p>
<p>使用多版本并发控制比锁定模型的主要优点是在 MVCC 里，对检索(读)数据的锁请求与写数据的锁请求不冲突，所以读不会阻塞写，而写也从不阻塞读。</p>
<p>在 PostgreSQL 里也有表和行级别的锁定机制，用于给那些无法轻松接受 MVCC 行为的应用。不过，恰当地使用 MVCC 总会提供比锁更好的性能。另外，由应用定义的咨询锁提供了一个获得不依赖于单独事务的锁的机制。</p>
</div>
<div>
<hr align="LEFT" width="100%">
<table summary="Footer navigation table" width="100%" border="0" cellpadding="0" cellspacing="0">
<tr><td width="33%" align="left" valign="top"><a href="mvcc.html" accesskey="P">后退</a></td><td width="34%" align="center" valign="top"><a href="index.html" accesskey="H">首页</a></td><td width="33%" align="right" valign="top"><a href="transaction-iso.html" accesskey="N">前进</a></td></tr>
<tr><td width="33%" align="left" valign="top">并发控制</td><td width="34%" align="center" valign="top"><a href="mvcc.html" accesskey="U">上一级</a></td><td width="33%" align="right" valign="top">事务隔离</td></tr>
</table>
</div>
</body></html>